<template>
  <svg aria-hidden="true" class="svg-icon">
    <use :xlink:href="symbolId" :fill="color" />
  </svg>
</template>

<script setup lang="ts">
  import { computed } from 'vue'

  const props = defineProps({
    prefix: { type: String, default: 'icon' },
    iconClass: { type: String, required: true },
    color: { type: String, default: '' }
  })

  const symbolId = computed(() => `#${props.prefix}-${props.iconClass}`)
</script>

<style scoped>
  .svg-icon {
    width: 1.2em;
    height: 1.2em;
    vertical-align: -0.2em;
    overflow: hidden;
    fill: currentColor;
    margin-right: 4px;
  }
</style>
